如何解决IAR不能设置断点的问题
写在前面
有网友问:我在使用IAR在线调试过程中不能打断点,但在编辑的时候可以打断点,一点击调试按钮之后,所打的断点就失效了······
类似的问题:在先调试过程中,在反汇编的窗口中可以设置断点,在C编译区不能设置断点。
查看断点的方法:菜单view->breakpoints 就会在窗口显示所有断点信息。
通常出现这类现象是因为你要加断点的位置并没有程序(或不匹配程序),也就是你的C代码和你的实际代码对不上号了。遇到以上问题,解决的办法一般有下面几种。
常见解决办法
1.Rebuild All重新编译
A.Project -> Clean:把前面编译后的文件删除;
B.Project -> Rebuild All:再重新编译所有文件。
这种情况比较常见,有可能是在更改了部分文件。
2.查看配置是否正确
A.生产Debug信息
Project -> Options -> C/C++ Compiler -> Output:勾选上“Generate debug informat” 这个选项。
B.链接包含Debug信息
Project -> Options -> linker -> Output:勾选上“Include debug information in output ” 这个选项。
3.代码优化等级较高
在某些场合下,比如要求执行代码的速度,或者代码容量比较大而芯片容量又有限,就需要对代码进行优化,优化的等级分多种。
没有特别要求,代码就可以不用优化。代码高度优化存在弊端,特别是代码不规范的情况下。有一点就是本文说的,高度优化的代码,会影响在线调试,可能你某部分代码被优化导致你不能打断点。
这个时候就容易出现:在先调试过程中,在反汇编的窗口中可以设置断点,在C编译区不能设置断点。
Project -> Options -> C/C++ Compiler -> Optimizations选择优化的等级:
4.代码处于条件编译未选中状态
什么是条件编译呢?
就是#if #else #endif 这类带有#的预处理编译。
如果你的代码不再预编译里面,则不能打断点。
5.推测的问题
我们都知道软件一般都会存在bug,即使是强大的Windows、iOS、Android操作系统也经常修复或升级。
若怀疑是IAR软件自身的问题,建议升级到最新。我个人喜欢尝试新鲜的东西,之前看过我文章的人都知道,Keil、IAR新版我和大家分享过。若你IAR出现此类问题,上面几种方法都无效,建议更新IAR版本:
其他问题都排除了,还有可能是Windows系统高度优化的问题,这个建议重装系统。
最后
微信搜索“EmbeddDeveloper” 或者扫描下面二维码、关注,查看更多精彩内容!